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(54) Systeme de telechargement d'objets ou de fichiers pour mtse a jour de logiciels 



(57) La prdsente invention conceme un systeme de 
tdltehargemant d'objets ou da fichters pour mise k jour 
de logiciats. 

Ce systdme de telechargement d'objets ou de fi- 
chiers pour mise k jour de bgiciels est caractdrise en 
ce que I'architecture du systeme d'exploitation compor- 
te une repartition des ditferentes tdches en modules lo- 
giciels relies entre eux par des liens dynamiques ou 
constitues de sous-programmes executabies presen- 
tant des liens de dependance principale avec d'autres 
parties du systeme d'exploitation, chacun des modules 
etant constitue de fichiers d'objets ou de librairies repre- 
sentees par des librairies de liens dynamiques 'dynamic 
links libraries* entre elles selon une pluralite de niveaux 
de dependance decrits dans leurs attributs respectifs. 
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Description 

[0001] La prdsente invention concerne un syst^me de t6l6chargement d'objets ou de fichiers pour mise k jour de 
logiciels, notamment pour les syst6mes de reproduction audiovisuelle declenchds par paiement de redevances. tels 

5 que juk6*box ou autres appareits. 

(0002) II est connu dans I'art ant6rieur des dispositifs de t6l6chargement de systdnne d'exploitation k travers un 
rdseau tels que. par exemple par la demande de brevet britannique 2 231 180. Cette demande de brevet enseigne 
d'effectuer le chargement d'un prennier calculateur lid d travers un r^seau ^ un deuxidme calculateur en chargeant un 
sous-ensemble du syst6nne d'exptoitation dans la mdmoire du prennier calculateur, le sous-ensemble comprenant les 

10 comnoandes permettant la copie des fichiers, la cr6ation d'un rdpertoire, le formatage du disque ainsi que le fonction- 
nement d'une connexion k travers le rdseau pour ensuite utiliser ce sous-ensemble pour transfdrer du second calcu- 
lateur {'ensemble des fichiers de syst^me Sexploitation sur le disque du premier calculateur. 
[0003] Dans ce type de t6l6chargement. il convient d'effectuer le chargement de I'ensemble du syst6me Sexploitation 
et de tous les fichiers du syst6me Sexploitation: Ceci am6ne done soit k limiter les t6l6chargements. soit h occuper. 

'5 pendant des temps relativement longs, des systdmes de t6l6conrvnunications pour eff ectuer des t6 16chargerrients dans 
le cas ou les systdmes d'exploitation ou les fichiers associds doivent dtre renouvel6s frdquemment. 
[0004] II est 6galement connu par le brevet americain N" 4 958 278 un sysi6me de t6l6chargement sur un terminal 
non pourvu de lecteur de disques. 

[0005] II est dgalement connu par le brevet f ran9ais N*" 2 682 786 un autre procddd de tdldchargement sur un terminal 

^0 non pourvu de disque dur. 

[0006] Enf in un dernier brevet europden N° 0 358 992 enseigne une mdthode de tdldchargement d travers un rdseau 
do sysieme d'exploitation ou de programmes exteutables sur un calculateur qui ne comporte pas de dispositif San>or- 
^rtgc ou d'autres dispositifs contenant le programme executable. Un premier programme rfanxir^age minimum est 
tranGlcfC dans un premier temps, puis ce premier programme d'annor^age minimum s'exdcute, 6tablit une liaison lo- 

2S giquc vers un disquo du serveur et autorise I'ordtnateur de requdte h traiter le disque du sen/eur comme un dispositif 
d'amor^ago local 

[0007] Lo bui do I'invention est d'une part, d'dviter la ndcessitd de rdanrwrcer le terminal sur lequel on t6l6charge et 
d'autre part, de pormettre de transferer des fichiers d'exploitation ou des parties de programme executable sans avoir 
a remit latiser la nnachine. tout en 6tanl sur que le fonctionnement du systems ne sera pas degrade par la version 
30 telechargee 

[0008] Ce but est attaint par le fait que Tarchitecture du systeme d'exploitation comporte une repartition des diffe- 
rentes taches en modules logiciels relies entre eux par des liens dynamiques ou constitues de sous-programmes 
executables. presentant des liens de dependance principale avec Sautres parties du systeme d'exploitation, chacun 
des modules etant constitue de fichiers d'objets ou de librairies representees par des librairies de liens dynamiques 
^ "dynamic links Itoraries' organisees entre elles selon une pluralite de niveaux de dependance decrlts dans leurs attri- 
buts respectifs. 

[0009] S6k)n une autre particularite, les attributs Sun objet ou Sune librairie indiquent le numero de version et les 
dependances de I'objet par rapport k Sautres objets. 

[0010] Sekxi une autre particularite, les attributs indiquent le niveau attribue aux nr>odules. 

^ [001 1 ] Selon une autre partk:ularite. les diff erentes tdches comprennent une tSche principale qui comporte un module 
(JUKECORE.DLL) qui est destine ^ charger les librairies de liens dynamiques (DLL), e initialiser le noyau du program- 
me, ^ initialiser le module de gestkxi des graphiques (GFX.DLL). k initialiser un module de chargement des librairies 
(WDLL.DLL): k charger un module Tetecom des tdches de telecommunications (TELECOM.DLL) et k lancer un pro- 
gramme d'interpreteur secran en tant que tdche principale. 

^ [001 2] Selon une autre particularite, le programme est subdivise en un certain nombre de modules deflnissant chacun 
une tdche specif ique k un terminal equipe Sau nr>oins un nf)odem de telecommunication et d'une unite centrale. 
[0013] Sekxi une autre particularite. cette tdche specifique est celle con-espondant d un juke-box et compone une 
tache principale specifique, un certain nombre de modules, definissanl les fonctions 'fenetres* de i'affichage, qui sont 
les suivants : 

SO 

- un nrKxlule K/OUSE.DJL d'exploitation des signaux souris ou de I'ecran tactile ; 

un module WMESSAGE.DJL Sexploitation des messages echanges entre les objets ; 
un nr>odule FIL.DJL de gestion des fichiers sur disques ; 
un module FILtO.DJL de lecture-ecriture de fichiers sur disques ; 
^ - un module JSTRUCTDJt de surveillarxze de tous les evenements generds par les equipements, tels que fecran 
tactile, la carte son. I'interlace de traitement des equipements monetaires. 

[0014] Se\Of\ une autre particularite, la tdche principale specifique de rapplication juke-box comporte un module 
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(SI LOAD. DLL) contenant la hbrairie du programme chargeur, destin^e ^ verifier les versions de Itbrairies de liens 
dynamiques requises, de les charger et d'appeler le rrKxjule des taches T6t6com pour effectuer le transfer! de fichiers. 
[0015] Sebn une autre particularity, ce rrKx^ule SILOA0.DLL corrtporte la liste dans un fichier (DLLDEFAULT) des 
versions minimales n^essaires au fonctionnement alnsi que la liste de toutes les fonctions reprdsentdes. soit par des 
5 bibltoth6ques (DATA JUKEBOX LIBRARY), soit par des fichiers d'objets (DJO. DATA JUKEBOX OBJECT). 

[0016] Selon une autre particutarit^, chaque objet ou biblioth^ue contient la liste de toutes les fonctions, dent la 
biblioth^que ou I'objet a besoin. ainsi que tes num^ros de version et les ddpendances. 

[0017] Sebn une autre particularity, le nrK)dule WDLLDLL comporte des rTK^yens de gdrer tous les nouveaux mo- 
dules, de verifier que les modules tdiychargds n'ont aucune ddpendance manquante et ont 6\6 charges avec les ver- 
'0 sions ndcessaires. 

[0018] Selon une autre particularity, le module SILOAD.DLL comporte des moyens de gdrer le chargement. des 
modules sp^cifiques k la tSche du terminal, k savoir tous les rrxxjules DJL d^jd ynumdrys ainsi que les nrxxlules de 
librairie juke-box constituds par un module WOBJECT DJL qui gd re les objets, le mixeur, les achats ; un module WCUR- 
SOR.DJL qui g^re les mouvements du curseur ; un module DBMAPl.DJL qui gdre la base de donnde ; un module 
15 WFONTS. DJL qui g6re tous les types de fonte ; un module PARSER. DLL (PARSER Programme d'analyse) qui analyse 
et gyndre les dcrans ^ partir du script et vdritie la grammaire d Tatde d'un module "QRAMMAR.DJL' et d'un module 
texique "LEXY.DJLV 

[0019] Selon une autre particularity, le module de chargement de librairie SILOAD.DLL comporte un nxxjule 'WIN- 
DER' qui contient la liste des fichiers qu'tl faut incture pour gyrer les (endtres d'un affichage fendtres pryvu sur le 
20 moniteur du terminal de type juke-box. 

[0020] Selon une autre particutarity, cette liste d'objets est constituye : 

d*un module objet 'OBJET WPSCREEN.DJO" qui permet de dyflnir la page principale sur le moniteur ; 
d'un module 'WSCREEN.DJO' qui permet de dyterminer dans cette page principale le nombre d'dcrans disponi- 
2S bicG ct ainsi pcrmottro Taffichago de plusieurs fonStres ou ycrans ; 

d'un modulo *WI MAGE. DJO* qui permet de dyterminer et de dyfinir dans I'ycran Timage qu'il utilisera ; 

d'un modulo 'WANIM.DJO' qui permet de dyfinir t'aninr^tion lorsque I'innage est animye ; 

d'un modulo "WBUTTON.DJO" qui permet de dyfinir et gyrer les boutons qui sont utilisys sur I'ycran de la page 

principale 

30 - d'un module "WL ABEL. DJO* qui permet de crder des ytiquettes permettant rycriture par-dessus un objet ; et 

d'un module 'WSCROLLER.DJO* qui permet de dyfinir des zones d'affichage k dyfilement ? entre deux points 
par exemple, vertical, horizontal, diagonal. 

[0021] Selon une autre particularity, I'ensembte de ces modules d'objets gyrys par la t§che principale. utilise une 
3S librairie 'JHANDLER* qui pernrtet. par des moyens. de dyfinir les utilisations fixes des ycrans et done de dyterminer 
queues sont les interfaces qui assurent la liaison avec les diffyrents objets dyfinis par les nrxxjules prycydents. 
[0022] Selon une autre particularity, la tdche SILOAD.DLL comporte des moyens de lancer ou charger le module 
*XCP.DJP* permettant de gyrer les tdches de paiennent telles que les systymes de ryceptkxi de billets ou les unitys 
de paiement d monnaie ou k carte et permet ygalement la sauvegarde des infornnations de base dans le IBUTPON. 
40 [0023] D'autres partcularitys et avantages de la prysente invention apparaltront plus clairement k la lecture de la 
description ci-apr^s faite en ryfyrence aux desslns annexys dans lesquels : 

ta figure 1 reprysente une vue schymatique du schyma ytectrique du matyriel constituant I'lntention. 

- la figure 2 reprysente un logigramme des relatkxis entre les modules de libralries et les modules d'objets. 

[0024] De prytyrence. mais cependant de maniyre non limitative, le systyme de reproduction audiovlsuelle utilise 
les yiyments matyriels ynumyrys et ryfyrencys ci-aprds. 

[0025] L'unity centrale 1 k microprocesseur est un systyme compatible PC de haute performance, le choix lors de 
la mise en oeuvre s'ytant porty sur un systyme du type Pentium qui possyde des nrwyens de mymorisation et les 
so caractyristkiues suivantes: 

compatibility avec le bus local Vesa. 
• antymymoire de processeur 256 kO minimum, 
mynrraire vive: RAM de 32 MO 
^ - ports syrie de haute performance, 

adaptateur graph k^ue type SVGA k microprocesseur 

- contrdleur de bus type SCSI/2, 
memoire vive RAM stalk^ue auto-alimentye. 



BNSOOCia <EP 0074a96A1_L> 



EP 0 974 896 A1 



[0026] Toute autre unitd centrate, poss^dant das performances equrvatentes ou supdrieures, pourra dtre utitis^e 
dans I'invention. 

[0027] Cette unit6 centrale connmande et g6r6 une circuit de conrimande de son (5). un circuit (4) de commande des 
t6l6communications. un circuit (3) de commande des entries, un circuit (2) de comnrnnde de la mdmortsation de masse 
et un circuit (6) de commande des moyens de visualisation. Les moyens de visualisation se composent principalement 
d'un moniteur vid6o (62) k 6cran plat sans entrelacement de type SVGA k haute r6solution et faible rayonnement, 
c'est ce moniteur qui est utilisd pour la reproductbn d'images (par example les couvertures d'albums des selections 
musicales), de graphiques ou de clips viddo, 

[0028] Des moyens de memorisation de masse (21 ). utilisant des disques durs de type SCSI haute vitesse et haute 
capacity, sont associds aux moyens de mdmorisation d6j^ presents dans te dispositif d microprocesseur. Ces moyens 
sen/ent au stockage d'infornnations audiovisuelles numerisdes et compress^es. 

[0029] Un adaptateur de modem de tdldcommunications (41 ) haute vitesse est intdgrd pour autoriser la liaison avec 
un rdseau de distribution d'informations audiovisuelles contrdid par un serveur central. 

[0030] Pour ta reproduction des informations sonores das selections musicales. le systdme comporte des haut- 
parleurs (54) recevant le signal d'un amplif Icateur-tuner (53) relid au circuit 6lectronique (5) incorporant deux tampons 
memoire (56. 57) et de type synth6tiseur de musique prdvu pour supporter un grand nombre de sources d'entree tout 
en fournissant une sortie prdsentant une quatitd de type CD (disque compact). 

[0031] De mdme, le circuit de commande des moyens de visualisation compone dgalemeni deux m6moires tampon 
(66. 67) dans le but explicits ultdrieurement. 

[0032] Une alimentation thermiquemeni r^guiee de 240 watts ventil6e fournil I'dnergie au sysl6me. Ceile alimentation 
est protegee contra les surintensites et les suroscillations. 

[0033] Le systeme de reproduction audiovisuelle g6re. par te biais de son circuit contrdleur d'entr6e (3). un 6cfan 
tactile (33) qui inclut un panneau de revdtement de ta vitre utilisant la technologie avancee d'onde da surface' ainsi 
qu'un contr6leur de bus de type AT. Get ecran tactile permet aprea avoir affiche sur le moniteur video (62) ou recran 
d'un teievisour (61 ) diverses informations do selection utilisees par les clients, ainsi que des informations do commande 
et de contrdle de gestion utitiedes par le gerant ou le proprietaire du systeme. II est egalement utilise d des fins de 
maintenance en combinaison avec un clavier exteme (34) qui peut dtre relte au systeme qui possede pour ceta un 
connecteur de clavier, contrdie par un verrou ^ cte (32) ^ travers le circuit d'interface (3). 

[0034] Le circuit rfentr6G (3) interface egalement le systeme avec un ensemble tetecommande (31) constitu6. par 
exemple. d*une tetecommande RF d frequence k radio. 

[0035] Un dispositif de paiement de redevances (35) est egalement relie au circuit d'interface d'entree (3). It est 
egalement possible d'utiliser tout autre dispositif qui permette la reception de tout mode de paiement par pieces, billets, 
jetons. cartes magnetiques ou d puces ou toute combinaison des moyens de paiement 

[0036] Pour loger le systeme, il est de plus prevu un chassis ou bdti avec garnitures exterieures personnalisablas. 
[0037] Outre ces elements, un microphone (55) sans fit est relie au contrdleur de son (5). ce qui permet de transformer 
ce dernier en un puissant systeme d'annonces et d'infomnations destinees au public ou eventuellament en machine 
de karaoke. De mSme un systeme de haut-parleurs sans fil peut etre utilise par le systeme. 
[0038] L'ensemble (31 ) de commande ^ distance permet au gerant. par exemple de derri6re le bar. d'acceder et de 
contrdler differentes commandos telles que: 

ta commande marche/arret du mcrophone, 

la commande de mise en sourdine des haut-parleurs, 

la comnr^de de contrdie de volume sonore, 

la commande d'annulation de la selection musicale en train d'etre ecoutee. 

[0039] Deux tampons (56. 57) sont assoctes au circuit contrdleur de son (5) pour penmettre de memoriser chacun. 
de ta^on alternative, une information correspondant ^ environ au nrK>ins un quart de seconde de son. De mdme deux 
tampons (66: 67) sont associes au circuit contrdleur de video (6) capabtes, chacun et alternattvemenl, da memoriser 
environ au moins un dixieme de seconde d'innage. Enfin un tampon respectif (46, 36, 26) est associe h chacun des 
circuits contrdleur de communk:ation(4), d'interface d'entree (3) et de memorisation (2). 

[0040] Le bgiciel d'exploitatk)n du systeme a ete eiabore autour d'una librairie d'outils et de san/icas tr^s largament 
orientes vers le domaine audiovisual dans un univers multimedia. Cette librairie inclut de maniere avantageuse un 
systeme d'exptoitation muttit^che performant qui autorise efficacement I'execution simuttanee de multiples fragments 
de code. Ce logiciel d'exptoitation permet ainsi les executions concurrentes. de maniere ordonnee et en evitant tout 
conflit. d'operatkxis realisees sur les moyens de visualisation, les moyens de reproduction sonore de meme que la 
gestion des liaisor^ de teiecommuncations au travers du reseau de distribution. De plus, ce k>giciel presente une 
grande flexibilite 

[0041] Le sysieme d'exptoitation est partage en modules comporlHni un premier module d'arrwjrQHge (7) lui-mdme 
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subdivisd en un premier module (70) de programme principal, appeld 'JUK.EXE', qui vdritie la m^moire et vdrifie si te 
minimum d'objets est present pour assurer le fonclionnement du juke-box ; un second module (71 ) \t6 dynamiquement 
et dependant de celui-ci est constitu6 par le module appel6 'JUKECORE.DLLV La fonction de ce second module (71) 
est de contenir les librairies de langage C et d'assurer la tSche principale. 

5 [0042] ^architecture du systdme d'expbitation comporte une rdpartitbn des differentes tdches en modules bgiciels 
relies entre eux par des liens dynamiques ou constitu^s de sous-programmes exdcutables prdsentant des liens de 
ddpendance principale avec d'autres parties du syst^me d'exploitation. Chacun des modules est constitud de fichters 
d'objets ou de librairies de liens dynamiques 'dynamic links library* organises selon une plurality de niveaux de dd- 
pendance ddcrits dans les attributs. Les attributs d'un objet ou d'une librairie indiquent le numdro de version et tes 

10 d^pendances du fichier d'objet ou de la librairie par rapport k d'autres fichiers d'objets, comme d^crit cl-aprds pour le 
module appeld PARSER.DJL. Chaque attribut indique le niveau attribu6 au nrKxJule. Ainsl. le module JUK.EXE (70) 
est de niveau sup6rieur aux modules JUKECORE.DLL (71), TLS.DLL (72). CRDE.DLL (73). GFX.DLL (74), WDLL. 
DLL (75). JEEP.DLL (9) et TELECOM.DLL (10). mais le module TELECOM.DLL (10) est dependant du nrxxiule JEER 
DLL (9) (voir lien 910), done de niveau inf6rieur au module JEERDLL (9). 

'5 [0043] De mdme. JEERDLL (9) (voir lien 759) est de niveau inf6rleur au module WDLLDLL (75). car d6pendant de 
celui-ci et TLS (lien 725) de niveau supdrieur d WDLL (75). Par contre, les modules TLS.DLL et GFX.DLL peuvent 
etre de mdme niveau. La tSche principale comporte un module (JUKECORE.DLL) destine k initialiser ou charger le 
module (73), le noyau du programme appeld 'CRDE.DLL', k initialiser ou charger le module (74) de gestion des gra- 
phiques (GFX.DLL), d initialiser ou charger le module (75) de chargement (WDLL.DLL) des librairies, k charger le 

20 module (10) T6ldcom des tSches de t6l6communicaltons (DLL), 6 charger te module (72) TLS.DLL qui contienl toules 

les utilisations n^cessaires au juke-box, aux tdl^coms, heure, d^cryptage, etc d initialiser ou charger la librairie 

des programmes JEERDLL (Juke Execution Exchange Protocol) assurant les t^ches de serveur d'int^grit^, de requdte 
de chargement et le diak>gue avec le serveur, et k lancer te module de programme (60. SILOAD.DLL) en tant que 
tdche principale. La t&che principale de I'application juke-box comporte le module (SILOAD.DLL) contenant la librairie 

2S du programme chargeur destinde h verifier les versions de librairie k liens dynamiques requises dans le nnodule de 
chargement des librairies (WDLLDLL), de les charger ou d'appeler le module des tdches, T6ldcom pour effectuer le 
iransfert de fichiers. Le nrK>dule WDLL DLL comporte la liste dans un fichier (DLL.DEFAULT) des versions minimales 
necessaires au fonctionnement ainsi que la liste de toutes les fonctions representees soit par des bibliothdques (LI- 
BRARY) (DLL, DJL), soit par des fichiers d'objets (DJO). Chaque objet ou biblioth^que contient la liste de toutes les 

30 fonctions, dont la bibliotheque ou I'objet a besoin. ainsi que les numdros de verson et les ddpendances. Le module 
de chargement des librairies WDLL.DLL assure la gestion de tous les nouveaux modules, s'assure des interd^pen- 
dances et vdrif ie que les modules tei^chargds n'ont aucune ddpendance et ont ete charges avec les versions neces- 
saires. La partie applk:ative (8) propre k un juke-box comporte un certain nombre de modules charges et lances par 
le nr^odule SILOAD.DLL et definissant les fonctions fendtres' de I'affichage, qui sont les suivantes : 

3S 

- un module (81 ) appeie MOUSE.DJL. d'exploitation des signaux souris ou de recran tactile : 

un module (82) appeie WMESSAGE.DJL d'expkDitation des messages echanges entre les objets et les differents 
autres nrx)dules ; 

un nxxjule (83) appeie FILDJL de gestion des fk:hiers sur disques ; 
40 • un module (84) appeie FILIO.DJL, de lecture-ecriture de fichiers sur disques ; 

un module (85) appeie JSTRUCTDJL, de surveillance de tous les evenements generes par les equipements, tels 
que recran tactile, la carte son, ^interface de traitement des equipements nDonetaire. 

[0044] Le module SILOAD.DLL gdre le chargement, des modules speclfiques d la tdche du terminal, ^ savotr tous 
^ tes modules DJL dejd enumeres ainsl que tes nrxxlules de librairie juke-box (87) constitues par un nruxlule appeie 
WOBJECT.DJL (870) qui gdre tes objets, tels que le mixeur, les achats ; un rrodule appeie WCURSOR.DJL (871) qui 
gere les mouvements du curseur ; un module (872) appeie DQMAPl.DJL qui gere la base de donnee ; un nrKxlule (673) 
appeie WFONTS.DJL qui gdre tous tes types de fonle ; un module (874) appeie PARSER.DJL (Programme d'analyse 
syntaxique) qui analyse et genere les ecrans d parttr du script et verifie la grammaire k I'aide du module (876)appeie 
so 'GRAMMAR. DJL' et d*un module (675) appeie 'l^XY.DJL' qui est le rTKXlule lexique d'assignation des fonctions des 
mots k I'interieur du langage. Le nrxxjule PARSER.DJL (874) contient dans son en-t6te de fichier les informations 
suivantes : 

- char •par6er_versionJnfo= 'DLLJNFO DJU" 

55 'DLL-NAME PARSER.DJL;' 

•VERSION 1;' 
'CREATOR KENDALF;' 
"REOUIRIES loMyydil;4;' 
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•REQUIRIES grammar-.djl;5"; 

[0045] Tous les modules et toutes tes librairies {DJO. DLL DJL) contiennent des informations semblabtes ^ celles 
du module PARSER.OJL et ces informations ddterminent les n6cessit6s de version et de d^endance. 

5 [0046] Ainsi. te module PARSER.OJL a besoin des modules LEXYDJL version 4 et du module GRAMMAR version 
5 pour permettre son exteution par le syst^me. Les fitehes doubles de la figure 2. reliant les ditf^rents modules entre 
eux, donnent I'ordre de chargement des diff 6rents fichiers. Ainsi, comme on I'a vu pr6cedemment, il f audra commencer 
par charger le module JUKE.EXE pour ensuite charger le nrxxJule JUKECORE.DLL et pouvoir. k partir du module 
JUKECORE.Oa, charger les modules GFX.DLU TLS.DLL. WDLLDLL, JEERDLU TELECOM.DLL. CRDE.DLL et 

10 SILOAD.DLL. 

[0047] Les filches uniques reprdsentent les ddpendances entre modules. Ainsi, la fl6che (91 ) indique que tes fichiers 
DJL et en particutier. DBMAPl.DJL sont dependants de CROE.DLL. La fidche (93) montre que tes fichiers DJO sont 
dependants du module WOBJECTDJL Le nrxxjule W06JECTDJL est tui-mdme dependant du module FILtO.DJL La 
neche (92a) indique que le module DBMAPl.DJL est dependant du module JSTRUCTDJL et la fieche (92b) le module 

IS DBMAPl.DJL est dependant du module WMESSAGE.DJL La fieche (98) indique que le module JSTRUCTDJL est 
dependant du module WMESSAGE.DJL. Le module WMESSAGE.DJL est dependant du nrradule MOUSE.DJL et le 
module FILIO.DJL etant dependant du module FIL.DJL Le module XCRDJP est dependant, par la fieche (856). du 
module JSTRUCTDJL et comme indique. par la fteche (826) du module WMESSAGE.DJL. Le nrK)dule JHANDLER 
est dependant, par la fieche (97). du nriodule WMESSAGE.DJL et corrime repr6sente, par la fl6che (96) du module 

20 JSTRUCTDJL. L© module SILOOPDLL est dependant, comme repr6sente par la fieche (95). du module JSTRUCT 
DJL el par la fieche (94) du module WMESSAGE.DJL. Le module TELECOM.DLL est dependant, comme indique par 
Id ficche (910), du nrKxJule JE EPDLL qui est tui-mSme dependant, comme montre par la fieche (959), du module WDLL. 
DLL Lc module WDLLDLL est dependant, par la fieche (725), du module TLS.DLL. De meme, la fieche (89c) montre 
quo to nxxjulc GRAMMAR. DJL est dependant du module LEXY.DLL et. par la fieche (99b). que le module LEXYDJL 

2S est dependant du module PARSER. DJLL Ainsi, comme on a pu le voir pr6cedomment. le modulo PARSER.DJL a 
bosom du nrxxiulo LEXYDJL et du nrKxJule GRAMMAR pour s'executer et la version 1 du module PARSER.DJL fait 
appol a la versKxi A du module LEXY.DJL et ^ la version 5 du module GRAMMAR.DJL. De mdme, le module WOBJECT 
DJL est dependant par la fieche (99a) du module PARSER.DJL. Ainsi. tous les modules et toutes les librairies .DJO. . 
DLL DJL contienneni des informations semblabtes ^ celles du module PARSER.DJL qui determinant les necessites 

50 de version des differents nrKxiules dont un nrxxlule donn6 est dependant. Ces infomriations donnent egalement les 
dependances du module vis-d-vis des autres nrxxlules. comme cela est indique par tes fieches sur ta figure 2. 
[0048] Le module de chargement de librairie SILOAD.DLL charge 6gatement ou lance un module SILOOPDLL (90) 
qui est une bande d'attente d'evenement. Un ensemble de modules (88) contient la liste des fichiers qu'it faut incture 
pour gerer les fenetres d'un affichage fenetres pr6vu sur le moniteur du terminal de type juke-box. 

2S [0049] Cette liste d'objets est constituee : 

- d'un fichier d'objets (883) "WPSCREEN.DJO' qui permet de definir la page principale sur le moniteur ; 

- d'un fichier d'objets (881) 'WSCREEN-DJO' qui permet de determiner dans cette page principale le nombre 
d'ecrans disponibtes et ainsi permettre I'affichage de plusieurs fenetres ou ecrans ; 

40 - d'un fichier d'objets (880) 'WIMAGE.DJO' qui permet de detemriiner et de definir dans recran I'image qu'il utiUsera ; 

- d'un fichier d'objets (882) "WANIM.DJO' qui permet de definir i'animation lorsque I'image est animee ; 

- d'un fichier d'objets (885) 'WBUTTON.DJO" qui pemaet de definir et gerer les boutons qui sont utilises sur fecran 
de la page principale tels que les boutons d'actbnnement utilises dans I'interface graphique definie dans la de- 
mar^de de brevet PCT WO 96/12258 ; 

4S . d'un fichier d'objets (884) "WLABEL DJO' qui permet de creer des etiquettes permettant I'ecriture par-dessus un 
objet ; et 

- d'un fichier d'objets (886) "WSCROLLER.DJO" qui permet de definir des zones d'affichage & defilement vertical. 

[0050] Une librairie appeieo 'JHANDLER' permet de definir les utilisations fixes des 6crans el done, de determiner 
so queues sont les interlaces qui assurent la liaison avec les differents objets d6finis par les modules precedents. 

[0051] Le module (86) de librairie •XCRDJP' permet de g6rer les tfiches de paiement tetles que tes systemes de 
reception de billets ou les unites de paiement k monnaie ou e carte et permet egalement ta sauvegarde des informations 
do base dans te IBUTTON qui est un circuit iniegr6 do memorisation de codes secrets pour I'utilisateur. 
[0052] Ainsi, lorsqu'un nouveau fichier est envoye par teiechargement au systeme. le fichier comporte des informa- 
ss lions sur son niveau qui depend du type de fichier. Les fichiers des images graphiques. par exemple WIMAGE.DJO, 
ont les niveaux les plus eteves et les fichiers de gestion des parties Hardware, tels que, par exemple XCRDJP. ont les 
niveaux les plus bas. Le nr>odule JEEPDLL v6rifie la logique de d6pendance en commen^ant par les fichiers de niveau 
les plus bas et en remontant vers tes fichiers sup6rieurs tout en s'assurant que les dependances necessaires entre 
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iGs fichiers ou librairies sont respectdes. De cette iaqon, une modification dans te module WOBJECTDJL va amoner 
te module JEEP.DLL k verifier que les infomnations de version necessaires au module WOBJECTDJL pour les fichiers 
DJO dependants at ndcessaires d son execution correspondent aux versions minimales requises par les informations 
inscrites dans le fichier WOBJECTDJL. Ainsi. si le module WOBJECTDJL necessite une version d6termin6e du rTX>- 
dute WPSCREEN.DJO. il vdrifiera que cette version est au minimum pr6sente et s'il n'y a qu'une version de niveau 
insuffisant, il signalera un probl^me, puis le module JEEP.DLL remontera les liens de ddpendance vers les noodules 
FILIO.DJL et FILDJL 

[0053] L'organisation du disque dur du Juke box est effectude de fa^on k comporter un repertoire C:\NEWJUKE qui 
contient les nouveaux fichiers Juke box lorsqu'on t6ldcharge de nouveaux modules, Un autre fichier C:\OLDJUKE 
contient la sauvegarde des versions stables des fichiers et modules n6cessaires au fonctionnement du Juke box. Le 
module JEEPDLL (JUKE EXECUTION EXCHANGE PROTOCOL) contient un gestionnaire automatique de fichiers 
qui consen/e la trace des modules et fichiers mis ^ jour en sauvegardant les fichiers anciens pendant un certain temps 
et en depla^anl les nouveaux fichiers dans le repertoire NEWJUKE. Cette tSche enregistre dgalement les fichiers sur 
les pistes du disque en cas d'incident soudain pendant rop6ration de t6l6chargement. Le nDodule JEEPDLL contient 
egalement un gestionnaire de redemarrage dont la responsabilite est de changer les niveaux d'execution des fichiers 
du Juke box une fois que le gestionnaire automatique de fichiers a determine qu'une mise d jour du Juke box s'etait 
produiie. Le nwdule JEEP.DLL g6n6re egalement un fichier MISDEPS.DAT. lorsque la detection d'une dependance 
manquanie a ete faite. Ce fichier contient des lignes de la forme NEEDPARSER.DLL version 2.0 ; NEEDLEXY.DLL 

-aversion 2.0, etc. Ce fichier permetauserveur par lecture dece fichier MISDEPS. DAT de determiner les modules 

sur te juke box el de les recharger 



Revendicatlons 

^5 1 . Syst6me do t6l6chargement d'objots ou de fichiers pour mise h jour da logiciels caracteris6 en co que {'architecture 
du systeme d'exploitatton comporte une repartition des differentes tdches en modules logiciels relies entre eux 
par des liens dynamiques ou constitues de sous-progrannmes executables presentant des liens de dependance 
principate avec d'autres parties du systeme d*expk)itatlon. chacun des nxidules etant constitue de fichiers d'objets 
ou de librairies representees par des librairies de liens dynamiques 'dynamic links libraries' organisees entre elles 

20 selon une pluralite de niveaux de dependance decrlts dans leurs attrlbuts respectifs. 

2. Systeme de teiechargement d'objets ou de fichiers pour mise k jour de logiciels seion la revendicatlon 1 , caracterise 
en ce que les attributs d*un objet ou d'une librairie tndk^uent le numero de version et les dependances de I'objet 
par rapport k d'autres objets. 

3S 

3. Systeme de teiechargement d'objets ou de fichiers pour mise k jour de iogk:lets selon la revendlcatkvi 2, caracterise 
en ce que les attrbuts Indiquent le niveau attribue aux nrxxjules. 

4. Systeme de teiechargement d'objets ou de fichiers pour mise k jour de k)giciels sekxi une des revendicatkxis 1 k 
^0 3, caracterise en ce que les differentes tdches comprennent une tSche principale qui comporte un module (JU- 

KECORE.DLL) qui est destine k charger tes librairies de liens dynamkijues (DLL), k initialiser le noyau du pro- 
gramme, k initialiser le nrxxlute de gestion des graphiques (GFX.DLL), k initialiser un module de chargement des 
librairies (WDLL.DLL), k charger un module Teiecom des tSches de teiecommunk:ations (TELECOM.DLL) et k 
lancer un programme d'interpreteur tf6cran en tant que tache principale. 

5. Systeme de teiechargement d'objets ou de fichiers pour mise k jour de logiciels selon la revendk:atkxi 4. caracterise 
en ce que te programme est subdivlse en un certain nombre de modules definlssant chacun une tdche specifique 
a un terminal equipe d'au rTK)lns un modem de teiecommunicatkxi et d'une unite centrale. 

^0 6. Systeme de teiechargement d'objets ou de fichiers pour mise k jour de logk;iels selon la revendk^atksn 5, caracterise 
en ce que cette tSche specifique est celle correspondant k un juke-box et comporte unetdche principale specifique, 
un certain rxsmbre de modules, definlssant les fonctlons 'fenetres* de Taffichage, qui sont les sulvants : 

un module MOUSE. DJL d'exploltatlon des signaux souris ou de t'ecran tactile ; 
un nDodule WMESSAGE. DJL d'exploltatlon des messages echanges entre les objets ; 
un module FIL.DJL de gestion des fichiers sur disques ; 
un module FILIO.DJL de lecture-ecriture de fichiers sur disques ; 

un module JSTRUCT DJL da surveillance de tous les evenements genere^ par les equipements. tela que 
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r^cran tactile, la carte son, Tinterface de traitement des dquipements mondtaires. 

7. Systdme de t6l6chargement d'objets ou de fichiers pour mise k jour de logiciels selon la revendication 5 ou 6. 
caract6rts6 en ce que la tSche principale spdcifique de I'application juke-box comporte un module (SILOAD.DLL) 
contenant la tibrairie du progranrvne chargeur, destinde k verifier les versions de tibrairies de liens dynanniques 
requises. de les charger et d'appeler le module des tSches Tdldcom pour effectuer le transtert de fichiers. 

8. Syst^e de t^ldchargement d'objets ou de fichiers pour mise k jour de logiciels selon la revendication 7, caractdrisd 
en ceque ce module SILOAD comporte la listedans un fichier (DLL.DEFAULT) des versions mininr«lesn6cessaires 
au fonctionnement ainsi que la liste de toutes les fonctions representees, sott par des biblioth6ques (DATA JUKE* 
BOX LIBRARY), soit par des fichiers d'objets (DJO. DATA JUKEBOX OBJECT). 



9. Systeme de teidchargement d'objets ou de fichiers pour mise k jour de logiciels selon la revendication 8. caract^risd 
en ce que chaque objet ou bibliotheque contient ta liste de toutes les fonctions. dont la btblbth^que ou I'objet a 
besoin, ainsi que les numdros de version et les dependances. 



1 0. Syst^me de teidchargement d'objets ou de fichiers pour mise k jour de logiciels selon la revendication 4, caractdrisd 
en ce que te module WDLLOLL comporte des moyens de gdrer tous les nouveaux modules, de verifier que les 
modules teiechargds n'ont aucune ddpendance manquante et ont M charges avec les versions ndcessaires. 

20 

1 1 . Systdme de tei^chargement d'objets ou de fichiers pour mise d jour de logiciels selon la revendication 7, caract6ris6 
en ce que le oKxlule SILOAD.DLL comporte des rrioyens de g^rer le chargement. des modules specifiques h la 
tdche du terminal, k savoir tous les modules DJL d^jd enumdr^s ainsi que les nrtodules de librairie juke-box cons- 
tituds par un module WOBJECTDJL qui g^re les objets. le mixeur, les achats ; un module WCURSOR.DJL qui 

2S g^re les nr>ouvements du cursour ; un nrvodule DBMAPl.DJL qui g6ro la base de donn6e ; un module WFONTS. 

DJL qui g^re tous les types de fonte ; un module PARSER.DLL (PARSER Programme d'anatyse) qui analyse et 
gdn^re les dcrans k partir du script et vdrifie la grammaire k I'aide d'un nrxxlule *GRAMMAR.DJL* et d'un module 
lexique 'LEXYDJLV ^ 

30 12. Systdme de tet^chargement d'objets ou de fichiers pour mise k jour de logiciels sebn la revendicatkDn 11 , carac- 
terisd en ce que le nrvodule de chargement de librairie SILOAD.DLL comporte un module 'WINDEF' qui contient 
la liste des fichiers qu'il taut inclure pour g^rer les fendtres d'un affichage f endtres prdvu sur le nrxxiiteur du terminal 
de type juke-box. 

3S 13, Systeme de teiechargement d'objets ou de fichiers pour mise k jour de logiciels sebn la revendication 12, carac- 
\6f\s6 en ce que cette liste d'objets est constitute : 

d'un module objet 'OBJET WPSCREEN.DJO* qui penmet de ddfinir la page principale sur te moniteur ; 
d'un nrx)dule 'WSCREEN.DJO' qui permet de determiner dans cette page principale le nombre d'ecrans dis- 
^ ponibles et ainsi permettre I'affichage de plusieurs fendtres ou ecrans ; 

d'un module "WIMAGE.DJO* qui pemnet de determiner et de definir dans recran I'image qu'il utilisera ; 
d'un module 'WANIM.DJO* qui pemnet de definir t'animation lorsque I'image est animee ; 
d'un module *WBUTTON.DJO* qui permet de definir et gerer les boutons qui sont utilises sur recran de la 
page principale ; 

4S ' d'un module *WLABELDJO* qui permet de creer des etiquettes permenant recriture par-dessus un objet ; et 
d'un module 'WSCROLLER.DJO' qui permet de definir des zones d'affichage d defilement ? entre deux points 
par exemple, vertical, horizontal, diagonal. 

14. Systeme de teiechargement d'objets ou de fichiers pour mise k jour de logiciels selon la revendication 13, carac- 
so terise en ce que Tensemble de ces modules d'objets geres par la tSche principale, utilise une librairie 'JHANDLER' 

qui permet. par des moyens. de definir les utiiisatkxis fixes des ecrans et done de determiner quel les sont les 
interfaces qui assurent ta liaison avec les difterents objets definis par les modules precedents. 

1 5. Systeme de teiechargement d'objets ou de fichiers pour mise k jour de logiciels selon la revendicatkx) 7. caracterise 
^ en ce que la t^he SILOAD.DLL comporte des nDoyens de lancer ou charger le nnodule 'XCP.DJP' permettant de 

gerer les tdches de paiement telles que les systdmes de reception de billets ou les unites de paiement h monnaie 
ou k carte et permet egalement la sauvegarde des informations de base dans le IBUTTON. 
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Figure 2 
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